Ngữ nghĩa Prolog

Một chương trình logic có ngữ nghĩa của riêng nó. Ngữ nghĩa quyết định những kết luận "đúng" nào có thể rút ra được từ một chương trình Prolog. Ví dụ một chương trình Prolog gồm một dữ kiện:

mèo(tôm).

Khi đó, ta có thể rút ra duy nhất một dữ kiện đúng là "tôm là một con mèo". Trong một ứng dụng Prolog, bạn có thể hỏi một trong hai câu hỏi sau để có được trả lời đúng:

?- mèo(tôm).yes.

?- mèo(X).X = tôm;no.

Trong ví dụ trên, "no" có nghĩa là không còn câu trả lời nào nữa. Mọi câu hỏi khác đều cho trả lời là sai. Điều này có nghĩa là trong một chương trình Prolog, người ta sử dụng giả thiết thế giới đóng, mọi thứ bạn khai báo là đúng, nếu không thì nó là sai. Vì vậy trong ví dụ trên, khi bạn hỏi "mitu có phải là một con mèo hay không", bạn sẽ nhận được câu trả lời "no".

Với một chương trình Prolog xác định, ngữ nghĩa của nó được định nghĩa là một mô hình tối thiểu của nó.

Với một chương trình Prolog bình thường, có nhiều loại ngữ nghĩa được sử dụng như ngữ nghĩa đầy đủ, ngữ nghĩa tối thiểu, ngữ nghĩa hoàn chỉnh,...

Đa số các chương trình biên dịch Prolog phổ thông (SWI-Prolog, GNU-Prolog) sử dụng ngữ nghĩa đầy đủ mà đi kèm là thủ tục suy diễn SLDNF.

Tài liệu tham khảo

WikiPedia: Prolog http://www.csse.monash.edu.au/~lloyd/tildeLogic/Pr... http://www.cs.kuleuven.ac.be/~remko/prolog/faq/fil... http://www.amzi.com/AdventureInProlog/advfrtop.htm http://www.amzi.com/ExpertSystemsInProlog/index.ht... http://eclipse.crosscoreop.com/ http://www.declarativa.com/interprolog/ http://inap.dialogengines.com http://www.visual-prolog.com/vip6/community/exampl... http://www.visual-prolog.com/vip6/tutorial/ http://kti.ms.mff.cuni.cz/~bartak/prolog/index.htm...